package com.noexcs.forum.dao;

import com.noexcs.forum.entity.DiscussPost;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * @author noexcs
 * @since 5/20/2022 5:57 PM
 */
@Mapper
public interface DiscussPostMapper {

    /**
     * 显示主页post（userId=0)，或者个人主页（userId!=0)
     *
     * @param userId 如果为0，则表示为所有用户的post，如果为非0，则为某个用户的个人主页
     * @param offset 每一页的起始行号
     * @param limit  这一页最多显示多少数据
     */
    List<DiscussPost> selectDiscussPosts(int userId, int offset, int limit);

    /**
     * 如果说需要动态拼接一个条件，并有且只有
     * 查询帖子的行数(Param注解用于给起始参数取别名；如果只有一个参数，并且在<if>里面使用，测必须加别名）
     *
     * @param userId
     * @return
     */
    int selectDiscussPostRows(@Param("userId") int userId);

    int insertDiscussPost(DiscussPost discussPost);

    DiscussPost selectDiscussPostById(int id);

    int updateCommentCount(int id, int commentCount);
}
